/** * Copyright (C) 2015 Zalando SE (http://tech.zalando.com) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.zalando.stups.tokens; import java.io.IOException; import java.net.URI; import java.util.Collections; import java.util.Date; import java.util.HashSet; import java.util.Map; import java.util.Set; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.TimeUnit; import org.assertj.core.api.Assertions; import org.junit.Before; import org.junit.Test; import org.mockito.Mockito; import org.zalando.stups.tokens.mcb.MCBConfig; public class TokenVerifyRunnerTest { TokenRefresherConfiguration configuration; private final URI tokenInfoUri = URI.create("http://localhost/access_token"); private TokenVerifierProvider tokenVerifierProvider; private Map<Object, AccessToken> accessTokens; private Set<Object> invalidTokens; @Before public void setUp() { accessTokens = new ConcurrentHashMap<>(); invalidTokens = Collections.newSetFromMap(new ConcurrentHashMap<Object, Boolean>()); configuration = Mockito.mock(TokenRefresherConfiguration.class); tokenVerifierProvider = Mockito.mock(TokenVerifierProvider.class); Mockito.when(configuration.getHttpConfig()).thenReturn(new HttpConfig()); Mockito.when(configuration.getTokenVerifierProvider()).thenReturn(tokenVerifierProvider); Mockito.when(configuration.getAccessTokenConfigurations()).thenReturn(getAccessTokenConfigurations()); } private Set<AccessTokenConfiguration> getAccessTokenConfigurations() { AccessTokensBuilder accessTokensBuilder = Mockito.mock(AccessTokensBuilder.class); Set<AccessTokenConfiguration> configurations = new HashSet<>(); for (int i = 0; i < 3; i++) { AccessTokenConfiguration configuration = new AccessTokenConfiguration("TOKEN_" + i, accessTokensBuilder); configuration = configuration.addScope("read_all"); configurations.add(configuration); long creatIonTimestamp = System.currentTimeMillis() - TimeUnit.MINUTES.toMillis(2); accessTokens.put("TOKEN_" + i, new AccessToken("12345678", "Bearer", 1, new Date(), creatIonTimestamp)); } return configurations; } @Test public void create() { TokenVerifier verifier = Mockito.mock(TokenVerifier.class); Mockito.when(configuration.getTokenInfoUri()).thenReturn(tokenInfoUri); Mockito.when(configuration.getTokenVerifierMcbConfig()).thenReturn(new MCBConfig.Builder().build()); Mockito.when(tokenVerifierProvider.create(Mockito.any(URI.class), Mockito.any(), Mockito.any())) .thenReturn(verifier); Mockito.when(verifier.isTokenValid(Mockito.anyString())).thenReturn(true).thenReturn(false).thenReturn(true); TokenVerifyRunner runner = new TokenVerifyRunner(configuration, accessTokens, invalidTokens); // execute runner.run(); runner.run(); runner.run(); try { runner.close(); } catch (IOException e) { // close } Mockito.verify(verifier, Mockito.atLeast(3)).isTokenValid(Mockito.anyString()); Assertions.assertThat(invalidTokens.size()).isEqualTo(1); } @Test public void olderThanMinute() throws IOException { try (TokenVerifyRunner runner = new TokenVerifyRunner(configuration, accessTokens, invalidTokens)) { AccessToken accessToken = new AccessToken("token", "Bearer", 13, new Date()); boolean result = runner.olderThanMinute(accessToken); Assertions.assertThat(result).isFalse(); long creatIonTimestamp = System.currentTimeMillis() - TimeUnit.MINUTES.toMillis(2); AccessToken accessToken2 = new AccessToken("token2", "Bearer", 13, new Date(), creatIonTimestamp); boolean result2 = runner.olderThanMinute(accessToken2); Assertions.assertThat(result2).isTrue(); } ; } }